'use strict'
// Template version: 1.2.7
// see http://vuejs-templates.github.io/webpack for documentation.

const path = require('path')
const glob = require('glob')
const chalk = require('chalk') //带颜色的打印
var  tempBuild={
  // Paths
  assetsRoot: path.resolve(__dirname, '../dist'),
  assetsSubDirectory: 'static',
  //定义发布后的路径 http://www.aaa.com:9090/bwieApp/
  assetsPublicPath: '/', 

  /**
   * Source Maps
   */

  productionSourceMap: true,
  // https://webpack.js.org/configuration/devtool/#production
  devtool: '#source-map',

  // Gzip off by default as many popular static hosts such as
  // Surge or Netlify already gzip all static assets for you.
  // Before setting to `true`, make sure to:
  // npm install --save-dev compression-webpack-plugin
  productionGzip: false,
  productionGzipExtensions: ['js', 'css'],

  // Run the build command with an extra argument to
  // View the bundle analyzer report after build finishes:
  // `npm run build --report`
  // Set to `true` or `false` to always turn it on or off
  bundleAnalyzerReport: process.env.npm_config_report,
  //index: path.resolve(__dirname, '../dist/index.html'),
  //one  : path.resolve(__dirname, '../dist/one.html'),
  //two  : path.resolve(__dirname, '../dist/two.html')
}

//根据getEntry获取所有入口主页面
var pages = getEntry('./src/pages/**/*.html');
var jss   = getEntry('./src/pages/**/*.js');

console.info(chalk.red("==================所有html文件==================================="));
console.info(pages);
console.info(chalk.red("==================所有js文件====================================="));
console.info(jss);
//每个入口页面生成一个入口添加到build中
for (var k in pages) {
  tempBuild[k] = path.resolve(__dirname, '../dist/' +pages[k].packagePath+ pages[k].fileName )
}

//获取所有入口文件
function getEntry(globPath) {
  console.info("config/index.js/getEntry=============================扫描路径%s",globPath);
  const pageRoot="./src/pages";
  var startIndex=pageRoot.length+1;
  var entries = {};
  glob.sync(globPath).forEach(function(filePath) {
	 var en={};
	 en.filePath=filePath;//文件原始路径
	 en.fileName = path.basename(filePath);//带后缀的文件名
	 en.baseFileName = path.basename(filePath, path.extname(filePath));//不带后缀的文件名
	 var packageName=path.dirname(filePath);
	 //./src/pages/mod1/table1->mod1/table1
	 packageName=packageName.substring(startIndex);
	 //包路径mod1/table1->mod1/table1/
	 en.packagePath=packageName+"/";
	 //mod1/table1->mod1.table1
	 packageName=packageName.replace(/\//g,".") ;
	 if(packageName!=''){//处理根路径
		 packageName=packageName+"."
	 }
	 //mod1.table1->mod1.table1.index
	 packageName=packageName+en.baseFileName
	 en.packageName=packageName;
     entries[packageName] = en;
  });
  return entries;
}



module.exports = {
  dev: {
    // Paths
    assetsSubDirectory: 'static',
    //定义测试的发布路径 http://localhost:9090/bwieApp/
    assetsPublicPath: '/',
    proxyTable: {},

    // Various Dev Server settings
    host: 'localhost', // can be overwritten by process.env.HOST
    port: 9000, // can be overwritten by process.env.PORT, if port is in use, a free one will be determined
    autoOpenBrowser: false,
    errorOverlay: true,
    notifyOnErrors: true,
    poll: false, // https://webpack.js.org/configuration/dev-server/#devserver-watchoptions-

    // Use Eslint Loader?
    // If true, your code will be linted during bundling and
    // linting errors and warnings will be shown in the console.
    useEslint: true,
    // If true, eslint errors and warnings will also be shown in the error overlay
    // in the browser.
    showEslintErrorsInOverlay: false,

    /**
     * Source Maps
     */

    // https://webpack.js.org/configuration/devtool/#development
    devtool: 'eval-source-map',

    // If you have problems debugging vue-files in devtools,
    // set this to false - it *may* help
    // https://vue-loader.vuejs.org/en/options.html#cachebusting
    cacheBusting: true,

    // CSS Sourcemaps off by default because relative paths are "buggy"
    // with this option, according to the CSS-Loader README
    // (https://github.com/webpack/css-loader#sourcemaps)
    // In our experience, they generally work as expected,
    // just be aware of this issue when enabling this option.
    cssSourceMap: false,
  }

  ,build   :  tempBuild
  ,pages   :  pages
  ,jss     :  jss
}
